

# Reference System: OPB IIC Using the ML403 Evaluation Platform

Author: Paul Glover, Ed Meinelt, Lester Sanders

# Summary

This application note describes how to build a reference system for the On-Chip Peripheral Bus Inter IC (OPB IIC) core using the IBM PowerPC<sup>™</sup> 405 Processor (PPC405) based embedded system in the ML403 Embedded Development Platform. The reference system is Base System Builder (BSB) based.

An IIC primer is given and an OPB IIC register reference is provided. The Xilinx Microprocessor Debugger (XMD) commands are used for verifying that the OPB IIC core operates correctly. Several software projects illustrate how to configure the OPB IIC core, set up interrupts, and do read and write operations. Some of the software projects interface the OPB IIC to the MicroChip 24LC04B serial EEPROM with an IIC interface, while others interface to the TotalPhase Aardvark Adapter, which provides IIC master and slave functionality. The procedure for using ChipScope<sup>™</sup> to analyze OPB IIC functionality is provided. The steps used to build a Linux kernel using MontaVista are listed. Simulation output files for analyzing basic IIC transactions are provided.

# Included Systems

This application note includes one reference system:

www.xilinx.com/bvdocs/appnotes/xapp979.zip

The project name used in xapp979.zip is ml403\_ppc\_opb\_iic.

# Required Hardware/Tools

Users must have the following tools, cables, peripherals, and licenses available and installed:

- Xilinx EDK 8.2.02i
- Xilinx ISE 8.2.03
- Xilinx Download Cable (Platform Cable USB or Parallel Cable IV)
- Monta Vista Linux v2.4 Development Kit
- Modeltech ModelSim v6.1d
- ChipScope v8.2

© 2007 Xilinx, Inc. All rights reserved. All Xilinx trademarks, registered trademarks, patents, and further disclaimers are as listed at <a href="http://www.xilinx.com/legal.htm">http://www.xilinx.com/legal.htm</a>. PowerPC is a trademark of IBM Inc. All other trademarks and registered trademarks are the property of their respective owners. All specifications are subject to change without notice. NOTICE OF DISCLAIMER: Xilinx is providing this design, code, or information "as is." By providing the design, code, or information as one possible implementation of this feature, application, or standard, Xilinx makes no representation that this implementation is free from any claims of infringement. You are responsible for obtaining any rights you may require for your implementation. Xilinx expressly disclaims any warranty whatsoever with respect to the adequacy of the implementation, including but not limited to any warranties or representations that this implementation is free from claims of infringement and any implied warranties of merchantability or fitness for a particular purpose.

# Introduction

This application note accompanies a reference system built on the ML403 development board. Figure 1 is a block diagram of the reference system.



Figure 1: OPB IIC Reference System Block Diagram

The system uses the embedded PowerPC (PPC) as the microprocessor and the OPB IIC core.

### **IIC Primer**

Figure 2 shows components on an IIC bus. Two IIC masters and three IIC slaves are shown. The master is responsible for setting up transactions. This includes generating the clock on SCL and defining which slave is involved in the communication, with an address field, and which component is transmitting and which component is receiving. Some components are slave only, while others can transition between master and slave operation.



Figure 2: IIC Bus

Figure 3 shows the START and STOP conditions. A START condition is a falling edge on SDA when SCL is high. A STOP condition is a rising edge on SDA when SCL is high. During data transfer, the data line is stable on SDA when SCL is high. Data transitions on SDA when SCL is low. Note that the START and STOP conditions are special conditions, violating the rule that data cannot transition while SCL is high.



Figure 3: Start and Stop Conditions

Figure 4 shows the format of the data transfer of two bytes on the IIC bus, beginning with the START (S) condition and ending with the STOP (P) condition, bounded by an idle IIC (F) bus. After a START condition, an eight bit field is transmitted containing a 7 bit address and a single Read/Write (R/W) bit. This 8 bit address/direction field is followed by an Acknowledge bit. After the address/data field, an eight bit data field is followed by an acknowledge bit (A). The last 8-bit data field is followed by a not acknowledge bit ( $\overline{A}$ ). This is followed by the STOP condition (P).

A single message can contain multiple start conditions, or a repeated start, without intervening STOP conditions.

In this data transfer, there are two acknowledge bits and one Not Acknowledge on the IIC bus. The distinction between a Not Acknowledge and a No Acknowledge is that Not Acknowledge occurs after a master has read a byte from a slave and a No Acknowledge occurs after a master has written a byte to a slave.

A synchronized SCL is generated with its LOW period determined by the device with the longest low period and its HIGH period determined by the device with the shortest HIGH period.



Figure 4: Data Transfer on the IIC Bus

Figure 5 shows the data transfer on the IIC bus, beginning with the START condition and ending with the STOP condition.



Figure 5: Generic Data Transer on the IIC Bus





Figure 6: Acknowledge on the IIC Bus

Figure 7 shows bus arbitration of two masters. The IIC bus is a multi-master bus. Masters monitor the IIC bus to determine if the bus is active. The bus is inactive when SCL and SDA are high for a bus free period tBUF of 1.3 us (FAST) or 4.7 us (STD). If two or more masters monitoring the IIC bus determine that the bus is free and begin a bus transaction simultaneously, the IIC bus is arbitrated to determine which master owns the bus. The IIC is a wired AND bus. This means that the bus is HIGH unless any component is driving it LOW.

Masters monitor the bus even after they have started a transaction as the master. If a master is not driving the IIC bus low and the bus is low, the master knows that another master is driving the IIC bus. If a master cannot get the SDA or SCL to go high it loses arbitration. When a master loses arbitration, it stops transmission. The master driving the bus with the last low when the other master(s) drives high becomes the master of the bus.



Figure 7: Arbitration of two Masters

# Reference System Specifics

In addition to the PowerPC405 processor and OPB IIC, this system includes DDR and BRAM memory on the PLB, and a UART and interrupt controller on the OPB. Figure 1 provides the block diagram. Table 1 provides the address map of the ML403 XC4VFX12. This is in the system.mhs.

### ML403 XC4VFX12 Address Map

Table 1: ML403 XC4VSX12 System Address Map

| Peripheral    | Instance            | Base Address | High Address |
|---------------|---------------------|--------------|--------------|
| PLB_DDR       | DDR_SDRAM_32Mx64    | 0x00000000   | 0x03FFFFFF   |
| OPB UART16550 | RS232_Uart_1        | 0x40400000   | 0x4040FFFF   |
| OPB INTC      | opb_intc_0          | 0x41200000   | 0x4120FFFF   |
| PLB BRAM      | plb_bram_if_cntlr_0 | 0xFFFF8000   | 0xffffffff   |
| OPB IIC       | IIC_EEPROM          | 0x40800000   | 0x4080FFFF   |

### **OPB IIC Registers**

Table 2 provides the register map for the OPB IIC core.

### Table 2: OPB IIC Registers

| Register                                           | Address            |
|----------------------------------------------------|--------------------|
| Device Global Interrupt Enable                     | C_BASEADDR + 0x01C |
| Interrupt Status Register                          | C_BASEADDR + 0x020 |
| Interrupt Enable Register                          | C_BASEADDR + 0x028 |
| Software Reset Register                            | C_BASEADDR + 0x040 |
| Control Register                                   | C_BASEADDR + 0x100 |
| Status Register                                    | C_BASEADDR + 0x104 |
| Transmit FIFO                                      | C_BASEADDR + 0x108 |
| Receive FIFO                                       | C_BASEADDR + 0x10C |
| Slave Address Register                             | C_BASEADDR + 0x110 |
| Transmit FIFO Occupancy                            | C_BASEADDR + 0x114 |
| Receive FIFO Occupancy                             | C_BASEADDR + 0x118 |
| Ten Bit Slave Address Register                     | C_BASEADDR + 0x11C |
| Receive FIFO Programmable Depth Interrupt Register | C_BASEADDR + 0x120 |
| General Purpose Output                             | C_BASEADDR + 0x124 |

Table 3 provides a description of the OPB IIC control register.

### Table 3: OPB IIC Control Register

| Bit(s) | Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0- 24  | Reserved | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                       |
| 25     | GC_EN    | <b>General Call Enable.</b> Setting this bit High allows the OPB IIC to respond to a general call address.                                                                                                                                                                                                                                                                                                      |
| 26     | RSTA     | <b>Repeated Start.</b> Writing a "1" to this bit generates a repeated START condition on the bus if the OPB IIC Bus Interface is the current bus Master. Attempting a repeated START at the wrong time, if the bus is owned by another Master, results in a loss of arbitration. This bit is reset when the repeated start occurs. This bit must be set prior to writing the new address to the Tx FIFO or DTR. |

| Bit(s) | Name             | Description                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27     | ТХАК             | <b>Transmit Acknowledge Enable.</b> This bit specifies the value driven onto the SDA line during acknowledge cycles for both Master and Slave receivers. Because Master receivers indicate the end of data reception by not acknowledging the last byte of the transfer, this bit is used to end a Master receiver transfer. As a slave, this bit must be set prior to receiving the byte to no acknowledge. |
| 28     | ТХ               | <b>Transmit/Receive Mode Select.</b> This bit selects the direction of Master/Slave transfers. This bit does not control the Read/Write bit that is sent on the bus with the address. The Read/Write bit that is sent with an address must be the LSB of the address written into the transmit FIFO.                                                                                                         |
| 29     | MSMS             | <b>Master/Slave Mode Select.</b> When this bit is changed from 0 to 1, the OPB IIC Bus Interface generates a START condition in Master mode. When this bit is cleared, a STOP condition is generated and the OPB IIC Bus Interface switches to Slave mode. When this bit is cleared by the hardware, because arbitration for the bus has been lost, a STOP condition is not generated.                       |
| 30     | Tx FIFO<br>Reset | Transmit FIFO Reset. This bit must be set if arbitration is lost or if a transmit error occurs to flush the FIFO.                                                                                                                                                                                                                                                                                            |
| 31     | EN               | OPB IIC Enable. This bit must be set before any other CR bits have any effect                                                                                                                                                                                                                                                                                                                                |

### Table 3: OPB IIC Control Register (Contd)

### Status Register (SR)

This register contains the status of the OPB IIC Bus Interface. All bits are cleared upon reset. Table 4 provides a definition of the status register.

Table 4: Status Register Bit Definitions

| Bit(s) | Name              | Description                                                                                                                                                                                                                                                                                                                                                         |
|--------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 - 23 | N/A               | Reserved.                                                                                                                                                                                                                                                                                                                                                           |
| 24     | Tx_FIFO_<br>Empty | <b>Transmit FIFO empty.</b> This bit is set High when the transmit FIFO is empty.                                                                                                                                                                                                                                                                                   |
| 25     | Rc_FIFO_<br>Empty | <b>Receive FIFO empty.</b> This is set High when the receive FIFO is empty.                                                                                                                                                                                                                                                                                         |
| 26     | Rc_FIFO_<br>Full  | <b>Receive FIFO full.</b> This bit is set High when the receive FIFO is full.<br>This bit is set only when all sixteen locations in the FIFO are full, regardless of the value written into Rc_FIFO_PIRQ.                                                                                                                                                           |
| 27     | Tx_FIFO_F<br>ull  | Transmit FIFO full. This bit is set High when the transmit FIFO is full.                                                                                                                                                                                                                                                                                            |
| 28     | SRW               | <b>Slave Read/Write.</b> When the IIC Bus Interface has been addressed as a Slave (AAS is set), this bit indicates the value of the read/write bit sent by the Master. This bit is only valid when a complete transfer has occurred and no other transfers have been initiated. A "1" indicates Master reading from Slave. A "0" indicates Master writing to Slave. |
| 29     | BB                | <b>Bus Busy.</b> This bit indicates the status of the IIC bus. This bit is set when a START condition is detected and cleared when a STOP condition is detected.                                                                                                                                                                                                    |

| Bit(s) | Name | Description                                                                                                                                                                                                                                                                                                                                                                                   |
|--------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30     | AAS  | Addressed as Slave. When the address on the IIC bus matches the Slave address in the Address Register (ADR), the IIC Bus Interface is being addressed as a Slave and switches to Slave mode. If 10-bit addressing is selected this device will only respond to a 10-bit address or general call if enabled. This bit is cleared when a stop condition is detected or a repeated start occurs. |
| 31     | ABGC | Addressed By a General Call. This bit is set high when another master has issued a general call and the general call enable bit is set high, $CR(1) = '1'$ .                                                                                                                                                                                                                                  |

### Table 4: Status Register Bit Definitions (Contd)

Table 5 provides a register description of the Interrupt Status register.

### Table 5: Interrupt Status Register

| Bit | Name   | Description                            |
|-----|--------|----------------------------------------|
| 24  | TFHE   | Transmit FIFO Half Empty               |
| 25  | NAAS   | Not Addressed as Slave                 |
| 26  | AAS    | Addressed as Slave                     |
| 27  | BNB    | Bus is not Busy                        |
| 28  | RFF    | Receive FiFO Full                      |
| 29  | TFE    | Transmit FIFO Empty                    |
| 30  | TE/STC | Transmit Error/Slave Transmit Complete |
| 31  | AL     | Arbitration Lost                       |

### Configuring the OPB IIC Core

Figure 8 shows how to specify the values of IIC generics in EDK. To access the dialog box in the figure, double click on the OPB IIC core in the EDK System Assembly View.

|             |        | δ To                                  | HDL<br>ggle Names Datasheet | Restore |
|-------------|--------|---------------------------------------|-----------------------------|---------|
| User        | System |                                       |                             |         |
| 4 <u>  </u> |        | OPB Clock Frequency                   | 10000000                    | \$      |
|             |        | Output Frequency of SCL Signal        | 100000                      |         |
|             |        | Use 10-bit Address                    | 7-bit addresses             | *       |
|             |        | Width of GPI0                         | 1                           | *       |
|             |        | Device Block ID                       | 0                           | * >     |
|             |        | Enable Module Identification Register | 0                           | ٢       |
|             |        |                                       |                             | _       |
|             |        |                                       |                             |         |
|             |        |                                       |                             |         |

Figure 8: Specifying the Values of OPB IIC Generics in EDK

### Microchip 24LC04

The Microchip Technology 24LC04B-I/ST with 4-KB EEPROM is provided on the ML403 board to store non-volatile data. The EEPROM write protect is tied off on the board to disable its hardware write protect. The IIC bus is extended to the expansion connector to allow additional devices to be added to the IIC bus.

Figure 9 shows IIC Bus Devices on the ML403.



Figure 9: ML403 IIC Bus

The 24LC04 is organized as two blocks of 256 bytes. It has a page write buffer of up to 16 bytes. The 24LC04 operates as an IIC slave. The 24LC04 accepts a control byte which contains control code, block select, and Read/Write fields shown in Figure 10. The control code

is '1010 for read and write operations. The A2, A1 bits are dont cares. The A0 bit is used by the master device to select which of the two 256-word blocks of memory are accessed. The 24LC04 write transactions are either a byte write or a page write. The page write begins the same as the byte write but instead of generating a stop condition the master transmits up to 16 data bytes to the 24LC04B. The 24LC04 supports current address, random, and sequential read operations.



Figure 10: 24LC04 Control Byte Allocation

# ML403 Board Information

According to the MicroChip 24L024B data sheet, the ML403 board has a low-level output current (IOL) of 3.0 mA at a VCC of 2.5v. The ML403 boards are shipped in the configuration shown in Figure 11. The board must be modified for this design to work correctly. Replace the 10K Ohm R70 and R71resistors with 833 or 1K Ohm resistors. See Answer Record 24049 for additional information.



Figure 11: ML40x Schematic for IIC Connections



The resistors are located on the board as shown in Figure 12.

Figure 12: ML40x Resistors

If additional IIC devices are connected to the bus via the expansion header as shown in Figure 13, insert additional pull-up resistors on the external signals connected at pins 31 and 32. The resistor values are dependent on the voltage.



Figure 13: Expansion Header

| IO_L8N_GC_LC_3_C12<br>IO_L8P_GC_LC_3_C13<br>IO_L7N_GC_LC_3_A17<br>IO_L7P_GC_LC_3_B17<br>IO_L6N_GC_LC_3_B10<br>IO_L6P_GC_LC_3_A10<br>IO_L5N_GC_LC_3_A15<br>IO_L5P_GC_LC_3_A16<br>IO_L4N_GC_VREF_LC_3_B12<br>IO_L4P_GC_LC_3_B13<br>IO_L3N_GC_LC_3_C14<br>IO_L3P_GC_LC_3_C15<br>IO_L2N_GC_VRP_LC_3_A11<br>IO_L2P_GC_VRN_LC_3_A12<br>IO_L1P_GC_CC_LC_3_B14 | C12<br>C13<br>A17<br>B17<br>B10<br>A10<br>A15<br>A16<br>B12<br>B13<br>C14<br>C15<br>A11<br>A12<br>B14 | SMA_DIFF_CLK_IN_N<br>SMA_DIFF_CLK_IN_P<br>IIC_SCL<br>IIC_SDA<br>DDR_CLK1_N<br>DDR_CLK1_P<br>DDR_A13<br>DDR_BA1<br>DDR_BA0<br>DDR_BA0<br>DDR_CLK_P<br>MOUSE_DATA<br>PHY_TXCLK<br>GPIO_LED_2<br>GPIO_LED_3<br>MOUSE_CLK |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IO_L1P_GC_CC_LC_3_B14<br>IO_L1P_GC_CC_LC_3_B15                                                                                                                                                                                                                                                                                                         | В14<br>B15                                                                                            | PHY_RXC_RXCLK                                                                                                                                                                                                         |
| FPGA_BANK3<br>2.5 VCC0                                                                                                                                                                                                                                                                                                                                 |                                                                                                       | X979 <u>1</u> 14_012907                                                                                                                                                                                               |

Figure 14 shows the FPGA pins driving the IIC Bus.

Figure 14: FPGA IIC Pins

### **TotalPhase Aardvark Adapter**

In the reference design, the OPB IIC in the XC4VFX12 on the ML403 board interfaces to the IIC in the Aardvark Adapter. The Aardvark IIC/SPI Embedded Systems interface is a multi-functional host adapter. The Aardvark Control Center software interacts with the Aardvark Adapter. The Control Center controls the functionality of the Aardvark Adapter. It uses the Aardvark IIC/SPI Software API. the Aardvark Adapter has six functional modes. The IIC-related modes are the IIC + SPI and IIC Bus Monitoring modes.

The Aardvark must be configured for use before the Aardvark Control Center software can be used to send and receive messages. Configuring the Aardvark Adapter binds the instance of the application with the available unit until the adapter is disconnected or the application is terminated.

The Configure Aardvark Adapter window is organized into two major sections: list of available adapters connected to the computer and list of the six operational modes. The main application window is divided into two sections. The top section contains the modules used with the Aardvark Adapter. The bottom section contains the transaction log which tracks all transactions that the Aardvark sends or receives. The transaction log contains the time, read or write transaction, master or slave, bit rate, address, number of bytes, and data.

| Figure | 15 | shows | the | Aardvark | Control | Center | GUI. |
|--------|----|-------|-----|----------|---------|--------|------|
|--------|----|-------|-----|----------|---------|--------|------|

| Aardvark 12C/SPI Control Center |                                                                                                                                                                                                                                                                                                     | I 🗆 🛛                  |
|---------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|
| File Aardvark, Help             |                                                                                                                                                                                                                                                                                                     |                        |
|                                 | Configure Aardvark Adapter                                                                                                                                                                                                                                                                          |                        |
|                                 | Configure Aardvark Adapter         Select an Aardvark port           Select an Aardvark port         Select a Mode           P         FW         HW           12C         SPI         GPI           0         3.30         3.00         Y           Y         Y         2237-08507         SPI-GPI |                        |
| Transaction Log<br>Time Mod.    | C Batch Mode<br>C 12C Monitor<br>Refresh List<br>OK Cancel                                                                                                                                                                                                                                          |                        |
| Port Getting                    | g list of Aardvarks                                                                                                                                                                                                                                                                                 | Clear Log Save to File |
| denni<br>denni                  | INSU OF MATUYAINS                                                                                                                                                                                                                                                                                   | X979 15 01290          |

Figure 15: Aardvark Control Center

# Interfacing to the OPB IIC on the ML403 Board to the Aardvark Adapter

Figure 16 shows the principle interface blocks when transferring data between the OPB IIC in the XC4VFX12 on the ML403 board and the IIC in the Aardvark Adapter.



Figure 16: Interfacing ML403 Board OPB IIC with the Aardvark Adapter

# Executing the Reference System using the Pre-Built Bitstream and the Compiled Software Applications

To execute the system using files inside the ml403\_ppc\_opb\_IIC/ready\_for\_download directory, follow these steps:

- 1. Change to the ml403\_ppc\_opb\_IIC/ready\_for\_download directory.
- Use iMPACT to download the bitstream by using the following: impact -batch xapp.cmd

- 3. Invoke XMD and connect to the MicroBlaze processor by the following command: xmd -opt xapp.opt
- Download the executable by the following command dow <path>/executable.elf

### **Executing the Reference System from EDK**

To execute the system using EDK, follow these steps:

- 1. Open system.xmp inside EDK.
- 2. Use Hardware  $\rightarrow$  Generate Bitstream to generate a bitstream
- 3. Download the bitstream to the board using **Device Configuration**  $\rightarrow$  **Download Bitstream**.
- 4. Invoke XMD with Debug Launch XMD.
- Download the executable by the following command. dow <path>/executable.elf

### Verifying the Reference Design with Xilinx Microprocessor Debugger

After downloading the bitstream file, issue the following XMD commands to verify that the ML403 reference design is set up correctly.

mrd 0x42600100 8

The expected value of the control register after a reset, located at 0x42600100 is 0x00000000. The expected value of the status register, located at 0x42600104, is 0x000000C0. The reset values of the Transmit and Receive FIFO registers are indeterminate. The reset values of the Transmit and Receive FIFO Occupancy and the Address registers is 0.

Except for the Status, , Receive FIFO, and Transmit and Receive Occupancy registers, all registers are writeable.

mwr 0x42600100 0xFFFFFFF

mrd 0x42600100 1

Using XMD commands, verify that the OPB IIC registers can be written and read as defined in Tables 2-5.

### **Software Projects**

The reference system contains the following software projects. In each software project directory, there is a src sub-directory for the source code. The connections in Figure 9 are used for the eeprom, low\_level\_eeprom, dynamic\_eeprom, and low\_level\_dynamic\_eeprom projects. These projects interface to the 24LC04. The connections in Figure 3 are used for the mult\_master and repeated\_start project. These projects interface to the IIC Bus via the Aardvark Adapter.

### **Projects interfacing to Microchip 24LC04**

**eeprom**: This project transmits and receives data using the high level (L1) software driver. The OPB IIC is the master and the 24LC04 is configured as the slave. The OPB IIC master writes data into the 24LC04 and reads it back.

**low\_level\_eeprom**: This project transmits and receives data using the low level (L0) software driver. The OPB IIC is the master and the 24LC04 is configured as the slave. The OPB IIC master writes data into the 24LC04 and reads it back. This is a polled mode example.

**dynamic\_eeprom**: This project transmits and receives data using the high level (L1) software driver. The OPB IIC is the master and the 24LC04 is configured as the slave. The OPB IIC master writes data into the 24LC04 and reads it back.

**low\_level\_dynamic\_eeprom**: This project transmits and receives data using the low level (L0) software driver. The OPB IIC is the master and the 24LC04 is configured as the slave. The OPB IIC master writes data into the 24LC04 and reads it back. This is a polled mode example.c

### **Projects interfacing to Aardvark Adapter**

**multi\_master**: This project transmits and receives data using the high level (L1) software driver. The OPB IIC is an IIC master and the IIC in the Aardvark is a master. The Microchip 24LC04B is configured as a IIC slave. The WP pin of the 24LC04 is hardwired to ground on the ML403. The interrupt mode is used. The IIC master in the Aardvark Adapter writes the data to the MicroChip 24LC04B with the No Stop option enabled. Any attempts to write data from the OPB IIC master results in a Bus Busy status. The Aardvark Adapter releases the bus by executing the FREE BUS command. When the bus is free, the OPB IIC master initiates a bus transaction.

**repeated\_start**: This project transmits and receives the data using the high level (L1) driver. The IIC devices on the ML300/ML310/ML410 boards do not support the repeated start option. The ML403 OPB IIC is configured as a master and the Aardvark Adapter IIC is configured as a IIC slave. The OPB IIC writes the data to the Aardvark IIC in multiple transactions with the repeated start option enabled. The external IIC device slave address is a 7 bit address defined by SLAVE\_ADDRESS. The number of bytes sent and received is defined by SEND\_COUNT and RECEIVE\_COUNT.

Figure 17 shows the repeated start example.

Specify 0x70 as the Address. The SPI Control is not used. The transaction log shows 16 write and 16 read transactions at address 70.

| lex: ente.<br>Rx Bytes:<br>number o<br>Savi | of bytes | "                                              | s Set                                          | Enable<br>Disab                                                                                                                                               | ed le                                                                                                                                                         | SPI CC<br>Polarity:<br>© Railing/F<br>Falling/F<br>Master   SI <sub>4</sub><br>SS Polarity:<br>MOSI Messa                                                                                                                                        | alling<br>Rising<br>ave  <br>(• SS Active                                                                                                                                                                                                                 | Phase:<br>© Sample/<br>© Setup/S<br>© Low © SS A                                                                                                                                                                                                                                                                                                            | 'Setup<br>ample                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Bit                                                                                                                                                                                                                                                                                                                                                                                                                                                 | t 4000 V kł<br>Order:<br>MSB<br>LSB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|---------------------------------------------|----------|------------------------------------------------|------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Rx Bytes:<br>number (                       | of bytes | Í                                              |                                                | Disab                                                                                                                                                         | e<br>le                                                                                                                                                       | <ul> <li>Rising/F</li> <li>Falling/F</li> <li>Master SIa</li> <li>SS Polarity:</li> </ul>                                                                                                                                                        | Rising<br>ave  <br>I SS Active                                                                                                                                                                                                                            | <ul> <li>Sample/</li> <li>Setup/S</li> </ul>                                                                                                                                                                                                                                                                                                                | ample                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                   | MSB<br>LSB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Rx Bytes:<br>number (                       | of bytes | Í                                              |                                                | Disab                                                                                                                                                         | e<br>le                                                                                                                                                       | <ul> <li>Rising/F</li> <li>Falling/F</li> <li>Master SIa</li> <li>SS Polarity:</li> </ul>                                                                                                                                                        | Rising<br>ave  <br>I SS Active                                                                                                                                                                                                                            | C Setup/S                                                                                                                                                                                                                                                                                                                                                   | ample                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | C                                                                                                                                                                                                                                                                                                                                                                                                                                                   | LSB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Rx Bytes:<br>number (                       | of bytes | Í                                              |                                                | Disab                                                                                                                                                         | le                                                                                                                                                            | Master Sla<br>SS Polarity:                                                                                                                                                                                                                       | eve  <br>SS Active                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Rx Bytes:<br>number (                       | of bytes | Í                                              |                                                |                                                                                                                                                               |                                                                                                                                                               | SS Polarity:                                                                                                                                                                                                                                     | • SS Active                                                                                                                                                                                                                                               | e Low C SS A                                                                                                                                                                                                                                                                                                                                                | active Hij                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | gh                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Send                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| number (                                    | of bytes | s)                                             |                                                | Set Re                                                                                                                                                        |                                                                                                                                                               | SS Polarity:                                                                                                                                                                                                                                     | • SS Active                                                                                                                                                                                                                                               | ELOW C SS A                                                                                                                                                                                                                                                                                                                                                 | uctive Hij                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | gh                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Send                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                             |          | s)                                             | 2                                              | Set Re                                                                                                                                                        |                                                                                                                                                               |                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Send                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                             |          |                                                | 8                                              | Set Re                                                                                                                                                        |                                                                                                                                                               |                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | ć                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Send                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Savi                                        | 1        |                                                | ×                                              | Set Re                                                                                                                                                        | sp.                                                                                                                                                           |                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Savi                                        | 1        |                                                |                                                | Serne                                                                                                                                                         | <u>эр.</u>                                                                                                                                                    |                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Savi                                        | 1        |                                                | X                                              |                                                                                                                                                               |                                                                                                                                                               |                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Savi                                        | 1        |                                                | ×                                              |                                                                                                                                                               |                                                                                                                                                               |                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Savi                                        | 1        |                                                |                                                |                                                                                                                                                               |                                                                                                                                                               |                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Savi                                        | 1        |                                                | 2                                              |                                                                                                                                                               |                                                                                                                                                               |                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Sav                                         | 1        |                                                | ~                                              |                                                                                                                                                               |                                                                                                                                                               |                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Sav                                         | 1        |                                                | -                                              |                                                                                                                                                               |                                                                                                                                                               |                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Sav                                         | 1        |                                                |                                                |                                                                                                                                                               |                                                                                                                                                               |                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Sav                                         |          |                                                |                                                |                                                                                                                                                               |                                                                                                                                                               |                                                                                                                                                                                                                                                  | <b>F</b> 20 2                                                                                                                                                                                                                                             | · · · · · · · · · · · · · · · · · · ·                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                                             | e        |                                                |                                                |                                                                                                                                                               |                                                                                                                                                               | Clear                                                                                                                                                                                                                                            | Load                                                                                                                                                                                                                                                      | Sav                                                                                                                                                                                                                                                                                                                                                         | e                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                                             |          |                                                |                                                |                                                                                                                                                               |                                                                                                                                                               |                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Mod.                                        | B/W      | 1.00                                           | Feat                                           | B.R.                                                                                                                                                          | Addr.                                                                                                                                                         | Len.                                                                                                                                                                                                                                             | Data                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                                             | B/W      | M/S                                            | Feat.                                          | B.H.                                                                                                                                                          |                                                                                                                                                               | Len.                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                             | 0.14                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | D 0                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                                             |          |                                                |                                                |                                                                                                                                                               | 0x50                                                                                                                                                          |                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                             | x: u Max                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | (HX:U                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                                             |          | S                                              |                                                |                                                                                                                                                               | 0×70                                                                                                                                                          |                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                             | x: 0 Max                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Bx 0                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 12C                                         | В        | S                                              | 622.0                                          |                                                                                                                                                               | 0x70                                                                                                                                                          | 16                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 12C                                         | B        | S                                              |                                                |                                                                                                                                                               | 0x70                                                                                                                                                          | 16                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 12C                                         | W        | S                                              |                                                |                                                                                                                                                               | 0x70                                                                                                                                                          | 16                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 12C                                         | W        | S                                              | 19718                                          |                                                                                                                                                               | 0x70                                                                                                                                                          | 16                                                                                                                                                                                                                                               | 00 00 00 00                                                                                                                                                                                                                                               | 0 00 00 00 00 00 0                                                                                                                                                                                                                                                                                                                                          | 00 00                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                                             |          |                                                |                                                |                                                                                                                                                               |                                                                                                                                                               |                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                             | []                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Clear Log                                                                                                                                                                                                                                                                                                                                                                                                                                           | Save to File                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                                             |          |                                                |                                                |                                                                                                                                                               | _                                                                                                                                                             |                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                                             | 12C      | 12C<br>12C<br>12C R<br>12C R<br>12C R<br>12C W | 2C S<br> 2C S<br> 2C R S<br> 2C R S<br> 2C R S | I2C         S           I2C         S           I2C         R           I2C         R           I2C         S           I2C         S           I2C         S | I2C         S           I2C         S           I2C         R           I2C         R           I2C         R           I2C         R           I2C         W | I2C         S         0x70           I2C         S         0x70           I2C         R          0x70           I2C         R         S            I2C         R         S            I2C         R         S            I2C         W         S | I2C         S         0x70           I2C         R         S         0x70           I2C         R         S         0x70         16           I2C         R         S         0x70         16           I2C         W/S         S         0x70         16 | I2C         S         I2C Stave E         I2C Stave E           I2C         S         0x70         I2C Stave E           I2C         R         S          0x70         16         00 01 02 0'           I2C         R         S          0x70         16         00 01 02 0'           I2C         W         S          0x70         16         00 01 02 0' | I2C         S         I2C Slave Disabled           I2C         S         0x70         I2C Slave Enabled + Max           I2C         R         S          0x70         16         00 01 02 03 04 05 06 07 0           I2C         R         S          0x70         16         00 01 02 03 04 05 06 07 0           I2C         W         S          0x70         16         00 01 00 00 00 00 00 00           I2C         W         S          0x70         16         00 00 00 00 00 00 00 | I2C         S         0x70         I2C Slave Disabled           I2C         S         0x70         I2C Slave Enabled - Max Tx: 0 Max           I2C         R         S         0x70         16         00 t0 t0 20 30 40 56 60 70 80 9           I2C         R         S          0x70         16         00 t0 t0 20 30 40 56 60 70 80 9           I2C         R         S          0x70         16         00 00 00 00 00 00 00 00 00 00 00 00 00 | I2C         S         I2C Slave Disabled         I2C Slave Disabled           I2C         S         0x70         I2C Slave Disabled         Max Tx: 0 Max Rx: 0           I2C         R         S          0x70         16         00 01 02 03 04 05 06 07 08 09           I2C         R         S          0x70         16         00 01 02 03 04 05 06 07 08 09           I2C         R         S          0x70         16         00 00 00 00 00 00 00 00 00 00 00           I2C         W         S          0x70         16         00 00 00 00 00 00 00 00 00           I2C         W         S          0x70         16         00 00 00 00 00 00 00 00           I2C         W         S          0x70         16         00 00 00 00 00 00 00 |

Figure 17: Repeated Start Example

**slave**: This project transmits and receives the data using the high level (L1) driver. The ML403 OPB IIC is configured as a slave and the Aardvark Adapter IIC is configured as a IIC master. The Aardvark Adapter IIC writes the data in test\_data to the OPB IIC and reads it back.

Figure 18 shows the slave example. The message is in transmit.txt, and is the sentence "Lester was here.". The transaction log matches the message. The address is 0x70. Click **Master Write** to generate the transaction.

| 2C Control                                                                                                                                                          |                                   | Bitrate         | Set 100                          | ▼ kHz        | SPI Cont                                                                                                  | rol                                                                    | Bitrate | Set 4000 - k                     |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|-----------------|----------------------------------|--------------|-----------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|---------|----------------------------------|
| Master   Slave  <br>Slave Addr: [0x70 (For H<br>Features: 10-Bit Addr 0<br>Master Write<br>Message<br>54 68 69 73 20 69 73 20 61 20<br>73 61 67 65 20 66 72 6F 6D 2 | ) 74 65 73 74 20                  | No Stop         | Free                             | Bus<br>Write | Polarity:<br>© Rising/Falling<br>C Falling/Rising<br>Master   Slave  <br>SS Polarity: © S<br>MOSI Message | Phase:<br>© Sample/Setup<br>© Setup/Sample<br>S Active Low © SS Active |         | Bit Order:<br>MSB<br>LSB<br>Send |
|                                                                                                                                                                     | Save                              | ]               | Maste                            | Read         | Clear                                                                                                     | Load Save                                                              | 1       | ×                                |
| Master Read                                                                                                                                                         | Save                              |                 | Maste                            | Read         | Clear                                                                                                     | Load Save                                                              |         |                                  |
| Master Read Number of Bytes: 25 Fransaction Log                                                                                                                     |                                   | u   1476        |                                  |              |                                                                                                           |                                                                        |         | <u>v</u>                         |
| Master Read                                                                                                                                                         | Save<br>Mod. RA<br>I2C W<br>I2C R | V M/S<br>M<br>M | Maste<br>Feat. B.R<br>400<br>400 | . Addr. 0x70 | Len. Da<br>27 54                                                                                          |                                                                        |         | M                                |

Figure 18: Slave Example

# Running the Applications

In XPS, select the **Applications** tab under the Project Information Area to view the **Software Project.** 

Figure 19 shows the structure of the dynamic\_eeprom project. Make the dynamic\_eeprom project active and the remaining software projects inactive.



Figure 19: Selecting the eeprom Software Project

Select **dynamic\_eeprom** and right click to build the project. If more than one software project is used, make the unused software projects inactive.

Connect a serial cable to the RS232C port on the ML403 board. Start up a HyperTerminal. Set Bits per second to **9600**, Data bits to **8**, Parity to **None**, and Flow Control to **None**, as shown in Figure 20.

| COM1 Properties          | ? 🔀                      |
|--------------------------|--------------------------|
| Port Settings            |                          |
|                          |                          |
| <u>B</u> its per second: | 9600                     |
| <u>D</u> ata bits:       | 8 💌                      |
| Parity:                  | None                     |
| <u>S</u> top bits:       | 1                        |
| <u>F</u> low control:    | None                     |
|                          |                          |
|                          | <u>R</u> estore Defaults |
|                          | K Cancel Apply           |
|                          | X979_20_012907           |

Figure 20: HyperTerminal Parameters

From XPS, start XMD and enter **rst**. Invoke GDB and select **Run** to start the application as shown in Figure 21. The eeprom.c code written for the ML403 shown in the figure runs without any modifications on this reference system.



Figure 21: Running dynamic\_eeprom in GDB

# Using ChipScope with OPB IIC

To facilitate the use of ChipScope to analyze OPB IIC hardware, the *iic.cdc* file is included in the ml403\_ppc\_opb\_iic/chipscope directory. The *iic.cdc* is used to insert a ChipScope ILA core into the opb\_iic core. The following steps are used to insert a core and analyze OPB IIC problems with ChipScope.

### 1. Invoke XPS. Run Hardware $\rightarrow$ Generate Netlist.

2. In the *iic.cdc* file, change the path <design\_directory> name to the directory in which the design files are installed. Three paths need to be changed.

### 3. Run Start $\rightarrow$ Programs $\rightarrow$ ChipScope Pro $\rightarrow$ ChipScope Inserter

4. From ChipScope Inserter, run File  $\rightarrow$  Open Project ii.cdc. Figure 22 shows the ChipScope Inserter setup GUI.

| ChipScope Pro Core Inserte | er                     |                                                       |                       |
|----------------------------|------------------------|-------------------------------------------------------|-----------------------|
| Eile Edit Insert Help      |                        |                                                       |                       |
|                            | <b>.</b>               |                                                       | 8                     |
| DEVICE                     | DEVICE                 |                                                       | Select Device Options |
| ICON                       | Design Files           |                                                       |                       |
| Core Utilization           | Input Design Netlist:  | 403_ppc_opb_lic\implementation\iic_eeprom_wrapper.ngc | Browse                |
|                            | Output Design Netlist: | 103_ppc_opb_lic\implementation\lic_eeprom_wrapper.ngo | Browse                |
| LUT Count: 97              | Output Directory:      | H:\designs\ml403_ppc_opb_lic\implementation           | Browse                |
| FF Count: 28               |                        |                                                       |                       |
| BRAM Count: 0              | Device Settings        |                                                       |                       |
|                            | Device Family: Virte:  |                                                       | 4                     |
|                            |                        | <b>P</b> *                                            |                       |
| Messages                   |                        |                                                       |                       |
|                            |                        |                                                       |                       |
|                            |                        |                                                       |                       |
|                            |                        |                                                       |                       |
|                            |                        |                                                       |                       |
|                            |                        |                                                       |                       |
|                            |                        |                                                       |                       |
|                            |                        |                                                       |                       |
|                            |                        |                                                       | X979 22 01290         |

Figure 22: ChipScope Inserter Setup

5. Figure 23 shows the GUI for making net connections. Click **Next** to move to the Modify Connections window. If there are any red data or trigger signals, correct them. The Filter Pattern can be used to find net(s). As an example of using the Filter Pattern, enter **intr** in the dialog box to locate interrupt signals. In the Net Selections area, select either **Clock**, **Trigger**, or **Data Signals**. Select the net and click **Make Connections**.

| Structure / Nets                                                                                                                                                              |           |         |        |                                          | Net Sel        | ections      |            |                        |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|---------|--------|------------------------------------------|----------------|--------------|------------|------------------------|
| / [lic_eeprom_wrapper]                                                                                                                                                        |           |         |        | •                                        | Trigge         | er Signals   | Data Si    | anals                  |
| (haTechiouTuchkeil                                                                                                                                                            |           |         |        | diffetion                                |                |              | lock Signa |                        |
|                                                                                                                                                                               |           |         |        | 2005                                     |                |              |            | 227.1                  |
|                                                                                                                                                                               |           |         |        | 20100                                    | Chann          |              |            |                        |
|                                                                                                                                                                               |           |         |        | 20100                                    | CH:0           |              |            | C_CONTRO               |
|                                                                                                                                                                               |           |         |        | 0000                                     | CH:1           |              |            | C_CONTRO               |
|                                                                                                                                                                               |           |         |        | 20100                                    | CH:2           |              | omaic_laid | C_CONTRO               |
|                                                                                                                                                                               |           |         |        | 10100                                    | CH:3           | /Sda_T       |            |                        |
|                                                                                                                                                                               |           |         |        | 0000                                     | CH:4           | /Scl_T       |            |                        |
|                                                                                                                                                                               |           |         |        | 20100                                    | CH:5           | /Sin_xfer    |            |                        |
|                                                                                                                                                                               |           |         |        | 0.00                                     | CH:6           |              |            | EG_INTERF              |
|                                                                                                                                                                               |           |         |        | -                                        | CH:7           |              |            | EG_INTERF              |
| (                                                                                                                                                                             |           |         |        | 1000                                     | CH:8<br>CH:9   |              |            | EG_INTERF              |
|                                                                                                                                                                               |           | aaaaaaa |        | 1.10                                     | CH:9<br>CH:10  |              |            | EG_INTERF              |
| Net Name   Pattern: *intr*                                                                                                                                                    |           | -       | Filter |                                          | CH:10<br>CH:11 |              |            | eg_interf<br>Eg_interf |
|                                                                                                                                                                               | 7         | 7       |        |                                          | CH:11<br>CH:12 |              |            | eg_interf              |
| Net Name                                                                                                                                                                      | Sourc     | Sourc   | Base   | 1                                        | CH:12<br>CH:13 |              |            | EG_INTERF              |
| c_eeprom/lic_I/REG_INTERFACE_MP2Bus_IntrEvent<0>                                                                                                                              | lic_eep   | FDR     | FDR    | -                                        | CH:13<br>CH:14 |              |            | EG_INTERF              |
| c_eeprom/lic_I/REG_INTERFACE_//P2Bus_IntrEvent<1>                                                                                                                             | lic_eep   | FDR     | FDR    | 1000                                     | CH:14<br>CH:15 |              |            | eg_interf              |
| c_eeprom/lic_I/REG_INTERFACE_MP2Bus_IntrEvent<2>                                                                                                                              | lic_eep   | FDR     | FDR    | 0,0040                                   | CH:15          |              |            | EG INTERF              |
| c_eeprom/lic_I/REG_INTERFACE_I/IP2Bus_IntrEvent<3>                                                                                                                            | lic_eep   | FDR     | FDR    | 1000                                     | CH:17          |              |            | EG INTERF              |
| c_eeprom/lic_I/REG_INTERFACE_I/IP2Bus_IntrEvent<4>                                                                                                                            | lic_eep   | FDR     | FDR    | 100                                      | CH:18          |              |            | EG INTERF              |
| c_eeprom/lic_I/REG_INTERFACE_I/IP2Bus_IntrEvent<6>                                                                                                                            | lic_eep   | FDR     | FDR    | 1000                                     | CH:19          |              |            | EG INTERF              |
| c_eeprom/lic_I/REG_INTERFACE_I/IP2Bus_IntrEvent<7>                                                                                                                            | lic_eep   | FDR     | FDR    |                                          | CH:20          |              |            | EG INTERF              |
| c_eeprom/lic_I/OPB_IPIF_SSP1_I/OPB_IPIF_I/OPB_BAM_I/intr2bus_                                                                                                                 |           |         | LUT4   | 2010                                     | CH:21          |              |            | EG INTERI              |
| c_eeprom/lic_I/OPB_IPIF_SSP1_I/OPB_IPIF_I/OPB_BAM_I/INTR_CT                                                                                                                   |           |         | FDRE   | a la | CH:22          |              |            | EG INTERF              |
| c_eeprom/lic_I/OPB_IPIF_SSP1_I/OPB_IPIF_I/OPB_BAM_I/INTR_CT                                                                                                                   |           |         | FDRS   |                                          | CH:23          |              |            | EG INTERF              |
| c_eeprom/lic_I/OPB_IPIF_SSP1_I/OPB_IPIF_I/OPB_BAM_I/INTR_CT                                                                                                                   |           |         | FDRS   | 2010                                     | graz g         | hie_copie    |            | co_and a               |
| c_eeprom/lic_I/OPB_IPIF_SSP1_I/OPB_IPIF_I/OPB_BAM_I/INTR_CT                                                                                                                   |           |         | FDRS   | 1                                        | DP0            |              |            |                        |
| c_eeprom/lic_I/OPB_IPIF_SSP1_I/OPB_IPIF_I/OPB_BAM_I/INTR_CT                                                                                                                   | . lic_eep | FDRS    | FDRS   | A STORE                                  | DP0            |              |            |                        |
| A ANY AND AND THE CODE HORE HORE DAM HATE OF                                                                                                                                  |           |         | FDRS   | 20100                                    |                |              |            |                        |
| c_eeprom/lic_I/OPB_IPIF_SSP1_I/OPB_IPIF_I/OPB_BAM_I/INTR_CT                                                                                                                   | lic eep.  | FDRS    | FDRS   |                                          | Make           | Connections  | 1          | Move Nets              |
| c_eeprom/lic_I/OPB_IPIF_SSP1_I/OPB_IPIF_I/OPB_BAM_I/INTR_CT                                                                                                                   |           |         |        |                                          |                |              |            | The Rest Neter         |
| c_eeprom/lic_I/OPB_IPIF_SSP1_I/OPB_IPIF_I/OPB_BAM_//INTR_CT<br>ic_eeprom/lic_I/OPB_IPIF_SSP1_I/OPB_IPIF_I/OPB_BAM_//INTR_CT                                                   | . iic_eep |         | FDRS   | - 3                                      |                |              |            |                        |
| c_eeprom/lic_UOPB_IPIF_SSP1_UOPB_IPIF_UOPB_BAM_UINTR_CT<br>c_eeprom/lic_UOPB_IPIF_SSP1_UOPB_IPIF_UOPB_BAM_UINTR_CT<br>c_eeprom/lic_UOPB_IPIF_SSP1_UOPB_IPIF_UOPB_BAM_UINTR_CT | . iic_eep | FDRS    | FDRS   | •                                        | Remov          | e Connectior | 15 🕹       | Move Nets              |
| c_eeprom/lic_I/OPB_IPIF_SSP1_I/OPB_IPIF_I/OPB_BAM_//INTR_CT<br>ic_eeprom/lic_I/OPB_IPIF_SSP1_I/OPB_IPIF_I/OPB_BAM_//INTR_CT                                                   | . iic_eep |         |        | •                                        | Remov          | e Connectior | 15         | Move Nets              |

Figure 23: Making Net Connections in ChipScope Inserter

7. Click Insert Core to insert the core into iic\_eeprom\_wrapper.ngo. In the ml403\_ppc\_opb\_IIC/implementation directory, copy iic\_eeprom\_wrapper.ngo to iic\_eeprom\_wrapper.ngc.

8. In XPS, run Hardware  $\rightarrow$  Generate Bitstream and Device Configuration  $\rightarrow$  Download Bitstream. Do not rerun Hardware  $\rightarrow$  Generate Netlist, as this overwrites the implementation/iic\_eeprom\_wrapper.ngc produced by the step above. Verify that the file size of the opb\_iic\_wrapper.ngc with the inserted core is significantly larger than the original version.

9. Invoke ChipScope Pro Core Analyzer by selecting

#### $\textbf{Start} \rightarrow \textbf{Programs} \rightarrow \textbf{ChipScope Pro} \rightarrow \textbf{ChipScope Pro Analyzer}$

Click on the JTAG chain icon located at the top left of Analyzer GUI. Verify that the message in the transcript window indicates that an ChipScope ICON is found.

10. The ChipScope Analyzer waveform viewer displays signals named DATA\*. To replace the DATA\* signal names with the signal names specified in ChipScope Inserter, select **File**  $\rightarrow$  **Import** and enter *iic.cdc* in the dialog box.

The waveform viewer is more readable when buses rather than discrete signals are displayed. The Reverse Bus Order operation below Add to Bus in the figure can be useful in analyzing ChipScope results.

| – DEV:0 MyDevice0 (System_                                                  |                           | Trigge | r Setup - DEV:ஆyyD  | evice2 (XC4VFX12) UNIT:0 MyILAO (ILA)                                     |             |                                  |  |
|-----------------------------------------------------------------------------|---------------------------|--------|---------------------|---------------------------------------------------------------------------|-------------|----------------------------------|--|
| - DEV:1 MyDevice1 (XCF32P)                                                  | <ul> <li>Match</li> </ul> | • 🗖    | M0:TriggerPort0     | Match Unit                                                                | Function == | Value<br>XXXX_XXX1               |  |
| <ul> <li>DEV:2 MyDevice2 (XC4VFX</li> <li>P- UNIT:0 MyILA0 (ILA)</li> </ul> | ch                        |        |                     | REG_INTERFACE_I/IP2Bus_IntrEvent<3>                                       |             | X                                |  |
| - Trigger Setup                                                             |                           | -      | (mag                | REG_INTERFACE_I/IP2Bus_IntrEvent<2>                                       |             | Х                                |  |
| - Waveform                                                                  |                           |        | 🗋 /iic_eeprom/iic_l | REG_INTERFACE_I/IP2Bus_IntrEvent<1>                                       |             | X                                |  |
| •                                                                           | Ş.                        |        | 🗋 /iic_eeprom/iic_l | REG_INTERFACE_I/IP2Bus_IntrEvent<0>                                       |             | X                                |  |
| gnals: DEV: 2 UNIT: 0                                                       |                           |        | 🗋 /iic_eeprom/iic_l | (IIC_CONTROL_I/arb_lost                                                   |             | Х                                |  |
| Trigger Ports                                                               |                           |        | 🗋 /iic_eeprom/iic_l | /IIC_CONTROL_I/bus_busy                                                   |             | X                                |  |
| No. 555 and No. 555                                                         |                           | _      | 🗋 /iic_eeprom/iic_l | (IIC_CONTROL_I/gen_stop                                                   |             | Х                                |  |
|                                                                             |                           |        | /iic_eeprom/iic_l   | /IIC_CONTROL_I/gen_start                                                  |             | 1                                |  |
|                                                                             |                           |        | ∑ /iic_eeprom/iic_l | /IIC_CONTROL_l/gen_start                                                  |             | 1                                |  |
|                                                                             | ► Trig                    | Add    | Active              | /IIC_CONTROL_l/gen_start<br>Trigger Condition Name<br>Trigger Condition 0 |             | 1<br>Trigger Condition Equ<br>M0 |  |
|                                                                             |                           | Del    | Active              | Trigger Condition Name<br>TriggerCondition0                               |             | Trigger Condition Equ<br>M0      |  |
|                                                                             | ► Trig ► Capture          | Del    | Active              | Trigger Condition Name                                                    | 612         | Trigger Condition Equ            |  |

Figure 24: Setting Up the Chipscope Trigger

11. Set the trigger in the Trigger Setup window. The trigger used depends on the problem being debugged. Change the **Windows to N samples** to a setting of **100**. Arm the trigger by selecting **Trigger Setup**  $\rightarrow$  **Arm**, or clicking on the **Arm** icon.

As shown in Figure 24, the trigger setup is to trigger when gen\_start is High.

12. Run **XMD** and/or **GDB** to activate the trigger patterns which cause ChipScope to display meaningful output.

13. ChipScope results are analyzed in the waveform window as shown in Figure 25. The waveforms may be easier to read if the discrete signals are removed after they are renamed. To share the results with remote colleagues, save the results in the waveform window as a Value Change Dump (vcd) file. The vcd files can be translated and viewed in most simulators. The vcd2wlf translator in Modeltech reads a vcd file and generates a wlf file for viewing in the Modeltech waveform viewer. The vcd file can be opened in the Cadence Design System, Inc. Simvision design tool by selecting File  $\rightarrow$  Open Database.

| Project                                          | Waveform - DEV:2 | MyD | evice | (XC4VFX | 12) UNIT: | ) MyILAO | (ILA) |     |       |     |     |     |       |     |
|--------------------------------------------------|------------------|-----|-------|---------|-----------|----------|-------|-----|-------|-----|-----|-----|-------|-----|
| EV.1 MyDevice1 (XCF32P<br>EV.2 MyDevice2 (XC4VFX | Bus/Signal       | х   | 0     | 00 -60  | -20       | 20       | 60    | 100 | 140   | 180 | 220 | 260 | 300   | 340 |
| P UNIT:0 MYILAO (ILA)                            | /iic_eeprom/ii   | 0   | 0     |         |           |          |       |     |       |     |     |     |       |     |
| - Trigger Setup<br>- Waveform                    | /iic_eeprom/ii   | 0   | 0     |         |           |          |       |     |       |     |     |     |       |     |
| +                                                | /iic_eeprom/ii   | 0   | 0     |         |           |          |       |     |       |     |     |     |       |     |
| als: DEV: 2 UNIT: 0                              | /iic_eeprom/ii   | 0   | 0     |         |           |          |       |     |       |     |     |     |       |     |
| ata Port<br>loger Ports                          | /iic_eeprom/ii   | 1   | 1     |         |           | 1        |       |     |       |     |     |     |       |     |
| 99017 0110                                       | /iic_eeprom/ii   | 1   | 1     |         |           |          |       |     |       |     |     |     |       |     |
|                                                  | /iic_eeprom/ii   | 1   | 1     |         |           |          |       |     |       |     |     |     |       |     |
|                                                  | /iic_eeprom/ii   | 0   | 0     |         |           | 7        |       |     |       |     |     |     |       |     |
|                                                  | /iic_eeprom/ii   | 0   | 0     |         |           |          |       |     |       |     |     |     |       |     |
|                                                  | /iic_eeprom/ii   | 0   | 0     |         |           |          |       |     |       |     |     |     |       |     |
|                                                  | /iic_eeprom/ii   | 0   | 0     |         |           | T        |       |     |       |     |     |     |       |     |
|                                                  | - /iic eeprom/ii | 0   | 0     |         |           |          |       |     |       |     |     |     |       |     |
|                                                  | /iic_eeprom/iid  | 0   | 0     |         |           |          |       |     |       |     |     |     |       |     |
|                                                  | /iic_eeprom/ii   | 0   | 0     |         |           |          |       |     |       |     |     |     |       |     |
|                                                  | /iic_eeprom/ii   | 0   | 0     |         |           | -        |       |     |       |     |     |     |       |     |
|                                                  | /iic eeprom/ii   |     | 0     |         |           |          |       |     |       |     |     |     |       |     |
|                                                  | /iic eeprom/ii   | 1   | 1     |         |           | -        |       |     |       |     |     |     |       |     |
|                                                  |                  |     |       |         |           |          |       |     |       |     |     |     |       |     |
|                                                  |                  | 4 > | 4 2 4 | L       |           | _        |       |     |       |     |     |     |       |     |
|                                                  |                  |     |       |         |           | X: -10   | 90    | 4 > | 0: -1 | 00  | 4 > | ∆(X | -0):0 |     |

Figure 25: ChipScope Analyzer Results

### **Linux Kernel**

New users of MontaVista Linux should read XAPP 765 Getting Started with EDK and Monta Vista Linux. The steps to build and boot a Linux kernel are given below. Steps 1-3, 7, 8 are run on a Linux machine with MontaVista Professional Edition© installed.

 Add /opt/montavista/pro/host/bin and /opt/montavista/pro/devkit/ppc/405/bin

#### to \$PATH.

- 2. Change to the ml403\_IIC/linux directory.
- 3. Run

```
tar cf - -C /opt/montavista/pro/devkit/lsp/xilinx-ml300-
ppc_405/linux-2.4.20_mvl31/ . tar xf -
```

4. To generate the Linux LSP in XPS, enter Software → Software Platform Settings. Select Kernel and Operating Systems, then select linux\_mvl31 v1.00.c.

5. Under **OS and Libraries**, set the entries as shown in Figure 26.

| re Platform<br>I Libraries | Configuration or OS: linux_mvl31 v1.01.c |               |                                         |        |                                                       |
|----------------------------|------------------------------------------|---------------|-----------------------------------------|--------|-------------------------------------------------------|
| Libranes                   | Name                                     | Current Value | Default Value                           | Туре   | Description                                           |
|                            | linux_mvl31                              |               | 111021030000000000000000000000000000000 |        |                                                       |
| at Handlers                | connected_periphs                        | ((RS23        |                                         | array  | Peripherals connected to Linux                        |
|                            | MEM_SIZE                                 | 0x04000000    |                                         | int    | Main Memory size in bytes                             |
|                            | PLB_CLOCK_FREQ_HZ                        | 10000000      |                                         | int    | PLB clock frequency                                   |
|                            | TARGET_DIR                               | //linux       |                                         | string | Destination directory for Linux BSP                   |
|                            | IIC_PERSISTENT_BASEADDR                  | 1024          | 1024                                    | int    | Start of persistent storage block in the EEPROM addre |
|                            | IIC_PERSISTENT_HIGHADDR                  | 2047          | 2047                                    | int    | End of persistent storage block in the EEPROM addres  |
|                            | IIC_PERSISTENT_EEPROMADE                 | DR 0xA0       | 0xA0                                    | int    | Address of the EEPROM on the IIC bus                  |
|                            | POWERDOWN_BASEADDR                       |               |                                         | int    | Start address of the powerdown feature                |
|                            | POWERDOWN_HIGHADDR                       |               |                                         | int    | End address of powerdown feature                      |
|                            | POWERDOWN_VALUE                          |               |                                         | int    | Value to power the board down                         |
|                            | <ul> <li>PCI BOARD</li> </ul>            |               |                                         | strina | Name of PCI configured board (ml310 or ml410)         |
|                            |                                          |               |                                         |        |                                                       |
|                            |                                          |               |                                         |        |                                                       |

Figure 26: BSP Settings

Verify that the target directory is the same as the directory containing the Linux source.

6. Click **Connect\_Periphs** and add the OPB\_INTC, OPB\_SYSACE, OPB\_IIC, OPB\_SPI, OPB\_IIC, and OPB 16550 peripherals, using the instance names shown in Figure 27.

|                    | ist of Parameter-Values                                                         | <b>X</b> |
|--------------------|---------------------------------------------------------------------------------|----------|
| Parameter Name: c  | connected_periphs                                                               |          |
| Parameter Descript | otion: Peripherals confidented to Linux                                         |          |
|                    |                                                                                 |          |
| periph_name        |                                                                                 |          |
| RS232_Uart         |                                                                                 |          |
| IIC_EEPROM         |                                                                                 |          |
| opb_intc_0         |                                                                                 |          |
|                    |                                                                                 |          |
|                    |                                                                                 |          |
|                    |                                                                                 |          |
|                    |                                                                                 |          |
|                    |                                                                                 |          |
|                    |                                                                                 |          |
|                    |                                                                                 |          |
|                    |                                                                                 |          |
|                    |                                                                                 |          |
|                    |                                                                                 |          |
| To add an element  | it to the parameter list, click "Add"                                           |          |
|                    | it to the parameter list, click "Add"<br>ent, select the row and click "Delete" |          |
|                    |                                                                                 |          |
|                    |                                                                                 | Cancel   |

Figure 27: Connected Peripherals

### Click OK.

- Select Software → Generate Libraries and BSPs to generate the LSP in ml403\_ppc\_opb\_iic/linux.
- From ml403\_ppc\_opb\_iic/linux, run patch\_nobspgen.
- 9. The m1403\_ppc\_opb\_iic/linux/.config is used to define the contents of the Linux kernel. Run

make oldconfig

An alternative is to enter make menuconfig and generate a new . config using the following options.

- Select General Setup
- Enable IIC. Disable PS/2 keyboard. Change to /dev/ram for booting from ramdisk.
- Select Input Core Support. Disable all.
- Select Character Devices. Disable Virtual. Leave Serial enabled. Disable Xilinx GPIO and Touchscreen.
- 10. Run make clean dep zImage.initrd. Verify that the zImage.initrd.elf file is in the ml403\_ppc\_opb\_iic/linux/arch/ppc/boot/images directory.
- 11. Invoke Impact and download implementation/download.bit to XC4VFX12. Either select Device Configuration → Download Bitstream from XPS or run the following

command from the command prompt: impact -batch etc/download.cmd

12. Invoke XMD. From the ml403\_ppc\_opb\_iic/linux directory, enter the following commands in the XMD window.

rst
dow arch/ppc/boot/images/zImage.initrd.elf
con

- 13. View the output in the HyperTerminal window. Login as **root**. Enter **cd** / and **ls** -1 to view the contents of the mounted Linux partition.
- 14. An alternative to downloading the Linux kernel executable is to load it into CompactFlash. The file used uses an ace file extension. To generate an ace file, run the command below from the ml403\_ppc\_opb\_iic directory.

xmd -tcl /genace.tcl -jprog -hw ./implementation/system.bit -ace ./implementation/ace\_system\_hw.ace -board ML403

Copy the ace file to a 64-512 MB CompactFlash (CF) card in a CompactFlash reader/writer. Remove the CF card from the CF reader/writer and insert it into the CompactFlash slot (J22) on the ML403 board. Power up the board.

# Simulation

The m1403\_ppc\_opb\_iic/simulation directory contains waveform log file, opb\_iic.wlf, for IIC transactions discussed in this section.

The opb\_iic.wlf files are easily loaded into the Modeltech simulator using the File  $\rightarrow$  Open command, specifying the \*.wlf file type.

The OPB IIC core has two Finite State Machine (FSM). The clock FSM has IDLE, START, SCL\_LOW\_EDGE, SCL\_LOW, SCL\_HIGH\_EDGE, SCL\_HIGH, STOP\_WAIT states. The main FSM has IDLE, HEADER, ACK\_HEADER, RCV\_DATA, XMIT\_DATA, ACK\_DATA, and WAIT\_ACK states.

Figure 28 shows the two OPB IIC cores in the simulation. The simulation is a Bus Functional Model simulatation of two OPB IIC cores. The IIC cores with addresses 20 and AA are designated iic\_20 and iic\_AA, with C\_BASEADDR of 0xE000000 and 0xE1000000, respectively. Both cores connect to SCL and SDA. The stimuli is provided by writing the OPB IIC registers.

As an example

write cr 41

enables the OPB IIC and sets the General Call enable. The address determines which OPB IIC is the target of the write, with  $0 \times E0000100$  for iic\_20 and  $0 \times E1000100$  for iic\_AA. It may be useful to consult the register map in Table 2 and the control (Table 3), status (Table 4), and interrupt status register (Table 5) definitions.

In most cases, after data is transmitted, the test waits for an interrupt from the OPB IIC.



Figure 28: OPB IIC Simulation

Internal signal names used in the OPB IIC core are provided in Table 6. *Table 6:* Internal Signals in OPB IIC

| Signal Name        | Functionality                        |
|--------------------|--------------------------------------|
| Txak               | Transmit acknowledge                 |
| Gc_en              | General call address enbale          |
| Ro_prev            | Receive overrun prevent              |
| Dtre               | Data transmit register empty         |
| Msms               | Master/Slave select                  |
| Dtr(7:0)           | Data Transmit Register               |
| Adr(7:0)           | IIC Slave Address Register           |
| Ten_adr(7:5)       | 10-bit Slave Address Register        |
| Bb                 | Bus Busy                             |
| Aas                | Addressed as slave                   |
| AI                 | Arbitration lost                     |
| Srw                | Slave read/write                     |
| Abgc               | Addressed by general call            |
| Data_iic(7:0)      | IIC data for microprocessor          |
| New_rcv_data       | New data received on IIC bus         |
| Tx_under_prev      | Transmit FIFO Empty IRQs             |
| slave_sda          | SDA value when slave                 |
| master_sda         | SDA value when master                |
| sm_stop            | Stop condition needs to be generated |
| rsta_tx_under_prev | Repeated start Tx underflow prevent  |



The simulation runs for 2000 ns as shown in Figure 29. There are 3 sections in the simulation, shown in the following figures.

Figure 29: Complete Simulation

In the first test, which is shown in Figure 30, the OPB IIC registers are read to verify the correct reset values. The interrupt registers are written and read. This occurs from 0 - 10 s Following this, an arbitration test is run. IIC\_AA is initially the bus master, with the write CR\_AA 0x0d.



Figure 30: Arbitrartion Lost Test Simulation

Figure 31 provides the Arbitration Lost test code. This pseudo-code can be tracked in the simulation.

| write ADR_20 0x20                             |
|-----------------------------------------------|
| write CR_20 40                                |
| write CR_AA 0x01                              |
| write ADR_AA AA                               |
| write IER_AA 0x04                             |
| write RC_FIFO_PIRQ_20 0x0                     |
| write DTR_AA 0x0                              |
| write CR_AA 0x0D Enables AA as master (5.9us) |
| write IPIER_20 0x01                           |
| write DTR_20 AA                               |
| write CR_20 0x0D Enables 20 as master         |
| wait_for_intr(30)                             |
| read IPISR 0xD3 Arbitration lost (260 us)     |
| write CR_20 0x01 Clears interrupt             |
| X979_31_012907                                |

Figure 31: Arbitration Lost Test Code



The second test, shown in Figure 32, runs from 575 s to 790 s Ths master, AA, receives 3C and 55 from 20. The following stimuli / results is seen in the opb\_iic.wlf file.

Figure 32: Simulation with iic\_AA as Master

Figure 33 provides the test code used in the simulation with the OPB IIC with the AA address as the master.

| write CR_20 0x40 GC, En                     |    |
|---------------------------------------------|----|
| write ADR_20 0x20 - Sets address as 0x20    |    |
| write CR_AA 0x01 - Enable                   |    |
| write ADR_AA 0xAA                           |    |
| write RC_FIFO_PIRQ_AA 0x0                   |    |
| write IER_AA 0x04 Enable DTRE interrupt     |    |
| write RC_FIFO_PIRQ 0x01 (473 us)            |    |
| write DTR_20 0x3C                           |    |
| write DTR_20 0x55                           |    |
| write DTR_AA 0x0 General Call               |    |
| write CR_AA 0x0D RSTA, TxAK, TX, MSMS, Enab | le |
| wait_for_intr                               |    |
| read SR_AA 0xC4 TFE, RFE, BB                |    |
| read ISR_AA 0xD4 TFHE, DTRE                 |    |
| write CR_AA 0x35 RSTA, MS, EN (547 us)      |    |
| write DTR_AA 0x21                           |    |
| write DTR_AA 0xFF                           |    |
| write IER_AA 0x08                           |    |
| wait_for_intr waiting for DRR_AA full       |    |
| read SR_AA 0x0C SRW, BB (678 us)            |    |
| write CR_AA 0x37 Clear FIFO                 |    |
| write CR_AA 0x35                            |    |
| read DRR_AA 0x3C                            |    |
| write ISR_AA 0xC*                           |    |
| write DTR_AA 0x21                           |    |
| wait_for_intr                               |    |
| read SR_AA 0x8C                             |    |
| read ISR_AA 0xCA TXER, DFF Full             |    |
| write CR_AA 0x41                            |    |
| read DRR_AA 0x55 (787 us)                   |    |
| write ISR_AA 0xC8                           |    |
| write IRE_AA 0x10 Enable Bus is not Busy    |    |
| wait_for_intr                               |    |

Figure 33: Test code with iic\_AA as Master



Figure 34 shows the third test shown in <code>opb\_iic.wlf</code>, run from 800 - 2000 us. IIC\_20 is the master writing to IIC\_AA, which is a 10-bit slave.

Figure 34: Simulation with iic\_AA as Master

Figure 35 provides the test code for simulation with IIC\_AA as master.

| write DTR_20 0xF2write DTR_20 0xA5write DTR_20 0xD5write DTR_20 0x96read TX_FIFO_OCY 0x01write DTR_20 0x87 |
|------------------------------------------------------------------------------------------------------------|
| read TX_FIFO_OCY 0x01 write DTR_20 0x87                                                                    |
|                                                                                                            |
|                                                                                                            |
| write CR_20 0x0D Tx, MS, En write DTR_20 0x78                                                              |
| write RC_FIFO_PIRQ 0x01 write DTR_20 0x60                                                                  |
| write IER_AA 0x20 Enable AAS write DTR_20 0x5A                                                             |
| wait_for_intr write DTR_20 0x4B                                                                            |
| read SR_AA C6 TFE, RFE, BB, AAS (893 us) write DTR_20 0x3C                                                 |
| write DTR_AA 0x11 write DTR_20 0x2D                                                                        |
| write DTR_AA 0x22 wrote DTR_20 0x1E                                                                        |
| write IER_AA 0x47 read TX_FIFO_OCY_20 0x0F 1207                                                            |
| read ISR_AA 0xA0 TFE, FFF write DTR_20 0x0F                                                                |
| read SR_20 C4 TFE, RFE, BB read TX_FIFO_OCY_20 0x0F                                                        |
| write IER_20 0x3F Enable DTRE read SR_20 0x1C TFF, SRW, BB                                                 |
| wait_for_intr DTRE occurs, D5 sent, and write DTR_20 0x00                                                  |
| throttle for 1500 ns read TX_FIFO_OCY_20 0x0F                                                              |
| write DTR_20 0xC3 (928 us) read SR_20 0x1C                                                                 |
| write DTR_AA AA write DTR_20 0xFF                                                                          |
| wait_for_intr DTRE occurs, C3, AA sent, and write RC_FIFO_PIRQ_AA 0x0D                                     |
| throttle for 1500 ns write CR_20 0x2D RSTA, TXAK,                                                          |
| write CR 0x25 RSTA, Master Receive, MS, Enable MS, EN Starts transmission                                  |
| write DTR_20 0xF3 read DRR_20 0x22                                                                         |
| read DRR_20 0xC3 read ISR_AA 0xEE                                                                          |
| wait_for_intr DRR full occurred, repeated start, write IER_AA 0x08                                         |
| F3 sent on bus wait_for_intr DRR_55 Full                                                                   |
| read ISR-20 0xCC RFF (1130 us) read DRR_AA 0xE1 1948 us                                                    |
| read DRR_20 0x11 No Ack Master Receive read DRR_AA 0xD2                                                    |
| write CR_20 0x15 read DRR_AA 0xC3                                                                          |
| write ISR_20 0xCC read DRR_AA 0xB4                                                                         |
| write IER_20 0x3B read DRR_AA 0xA5                                                                         |
| wait_for_intr DRR full, 0x22 received, throttle read DRR_AA 0x96                                           |
| for 1500 ns read DRR_AA 0x87                                                                               |
| write DTR_20 0xF2 Most significant address read DRR_AA 0x78                                                |
| write DTR_20 0xD5 Least significant address read DRR_AA 0x69                                               |
| write DTR_20 E1 read DRR_AA 0x5A                                                                           |
| read TX_FIFO_OCY 0x02read SR_AA 0x8E read DRR_AA 0x4B                                                      |
| read DRR_AA 0xAA read DRR_AA 0x3C                                                                          |
| read SR_AA 0xCE read DRR_AA 0x2D                                                                           |
| write DTR_20 0xD2 read DRR_AA 0x1E                                                                         |
| write DTR_20 0xC3 write CR_20 0x09 TxAK, EN                                                                |
| write DTR_20 0xB4 write DTR_20 0x55                                                                        |
| read TX_FIFO_OCY_20 0x05                                                                                   |
| read SR_20 0x0C SRW, BB                                                                                    |

X979\_35\_012907

Figure 35: Test Code for Simulation with iic\_20 as Master

# References

DS434 OPB IIC Bus Interface (v1.02a) XAPP765 Getting Started with EDK and MontaVista Linux ML40x Embedded Development Platform User Guide UG080 (v2.5) May 24, 2006 ChipScope ILA Tools Tutorial The IIC Bus Specification Version 2.1 January 2000 Philips Semiconductors

# Revision History

The following table shows the revision history for this document.

| Date    | Version | Revision                |
|---------|---------|-------------------------|
| 2/26/07 | 1.0     | Initial Xilinx release. |